МІНІСТЕРСТВО ОСВІТИ І НАУКИ УКРАЇНИ
НАЦІОНАЛЬНИЙ УНІВЕРСИТЕТ “ЛЬВІВСЬКА ПОЛІТЕХНІКА”
Звіт
про виконання лабораторної роботи №2
з курсу
“ Програмування комп’ютерної графіки”
Львів – 2010
Мета роботи: набути практичних навиків в складанні програм для побудови графіків в середовищі Microsoft Visual Studio C++ 2008
ЗАВДАННЯ
Написати програму, яка будує в середині екрану систему координат ХY і на ній графік функції Y = F(X), якщо аргумент або параметр змінюється на проміжку [a , b] з кроком h. Варіанти беруть з таблиці 1 за вказівкою викладача.
Таблиця 1. Завдання до лабораторної роботи
№
п/п
Функція
Інтервал
Крок
3
y=90*cos(x+ln(x)/20)
x=[0, 180]
h=0.15
Список змінних, які використовуються в коді програми, та їх пояснення:
Xmash, Ymash – машинні координати значень х та у які обчислюємо з даного нам рівняння на заданому проміжку;
Xcen, Ycen – координати центру від яких і починаємо побудову графіка.
CPoint MoveTo(int x, int y)- переміщує поточну вершину. x,y визначають координати нової поточної вершини. Повертає x- та y-координати попередньої поточної вершини як CPoint об'єкт.
BOOL LineTo(int x, int y)-малює лінію з поточної вершини до вершини з координатами x, y. Поточна вершина переміщується у вершину з коордиатами x, y. При успішному виконанні функції повертає TRUE, інакше FALSE.
BOOL TextOut(int x, int y, const Cstring& str)- виводить стрічку на екран. х,y задають координати початкової вершини виведення тексту. Str об'єкт типу Cstring, який містить текст для виведення. При успішному виконанні функція повертає TRUE, інакше FALSE.
Xmash, Ymash, Xcen, Ycen- змінні типу int.
D_Xmash, D_Ymash, D_Yreal, D_Xreal, Ymax, Ymin, x, y, Kx, Ky- змінні типу double.
Блок-схема алгоритму програми:
Остаточна версія програми:
#include "stdafx.h"
#include "Lab2.h"
#include "ChildView.h"
#include "math.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
// CChildView
CChildView::CChildView()
{
}
CChildView::~CChildView()
{
}
BEGIN_MESSAGE_MAP(CChildView, CWnd)
ON_WM_PAINT()
END_MESSAGE_MAP()
// CChildView message handlers
BOOL CChildView::PreCreateWindow(CREATESTRUCT& cs)
{
if (!CWnd::PreCreateWindow(cs))
return FALSE;
cs.dwExStyle |= WS_EX_CLIENTEDGE;
cs.style &= ~WS_BORDER;
cs.lpszClass = AfxRegisterWndClass(CS_HREDRAW|CS_VREDRAW|CS_DBLCLKS,
::LoadCursor(NULL, IDC_ARROW), reinterpret_cast<HBRUSH>(COLOR_WINDOW+1), NULL);
return TRUE;
}
void CChildView::OnPaint()
{
CPaintDC dc(this);
int Xmash, Ymash, Xcen, Ycen;
double D_Xmash, D_Ymash, D_Yreal, D_Xreal;
double x, y, Kx, Ky;
Xcen=40;
Ycen=344;
dc.MoveTo(0, Ycen);
dc.LineTo(1366, Ycen);
dc.MoveTo(Xcen,0);
dc.LineTo(Xcen,768);
// Знаходження коефіцієнтів розширення
double Ymax, Ymin;
for(x=0; x<=180; x=x+0.15)
{
y=90 * cos(x+log(x)/20);
D_Ymash = Ycen - y;
Ymax=80;
Ymin=0;
if(y>Ymax)
y=Ymax;
if(y<Ymin)
y=Ymin;
}
D_Yreal=Ymax-Ymin;
D_Ymash=Ycen-D_Yreal;
Ky=D_Ymash/D_Yreal;
D_Xreal=1360;
D_Xmash=Xcen+D_Xreal;
D_Xreal=180+Xcen;
Kx=D_Xmash/D_Xreal;
// Побудова графіка
Ymax=Ycen, Ymin=Ycen;
for(x=0; x<=180; x=x+0.15)
{
y=90 * cos(x+log(x)/20);
Xmash = Xcen + x*Kx;
Ymash = Ycen - y*Ky;
{
dc.LineTo(Xmash, Ymash);
dc.MoveTo(Xmash, Ymash);
}
}
// Малюємо > на Y
dc.MoveTo(Xcen, 0);
dc.LineTo(Xcen-15, 15);
dc.MoveTo(Xcen, 0);
dc.LineTo(Xcen+15, 15);
// Малюємо > на X
dc.MoveTo(1365, Ycen);
dc.LineTo(1350, Ycen+10);
dc.MoveTo(1365, Ycen);
dc.LineTo(1350, Ycen-10);
// Підписуємо осі координат
const CString Xstring("X");
dc.TextOutW(1340, Ycen+15, Xstring);
const CString centr("0");
dc.TextOutW(Xcen-15, Ycen+4, centr);
const CString Ystring("Y");
dc.TextOutW(Xcen-20, 0, Ystring);
for(int r=-100; r<=100; r+=10)
{
dc.MoveTo(Xcen-5, Ycen + r * Ky);
dc.LineTo(Xcen+5, Ycen + r * Ky);
}
for(int q=0; q<=180; q=q+10)
{
dc.MoveTo(Xcen + q * Kx, Ycen-10);
dc.LineTo(Xcen + q * Kx, Ycen+10);
}
//підписуємо осі координат
const CString Y1("2...